/**
 * 你是一个专业的小偷，计划偷窃沿街的房屋，每间房内都藏有一定的现金。这个地方所有的房屋都 围成一圈 ，这意味着第一个房屋和最后一个房屋是紧挨着的。同时，相邻的房屋装有相互连通的防盗系统，如果两间相邻的房屋在同一晚上被小偷闯入，系统会自动报警 。
 *
 * 给定一个代表每个房屋存放金额的非负整数数组，计算你 在不触动警报装置的情况下 ，今晚能够偷窃到的最高金额。
 * https://leetcode.cn/problems/house-robber-ii/description/
 * 题解：https://labuladong.gitee.io/algo/3/28/95/
 */
class RobTwo {
    public int rob(int[] nums) {
        int n=nums.length;
        int[] dp1=new int[n+1];
        int[] dp2=new int[n+1];
        if(n==1) {
            return nums[0];
        }
        for(int i=n-2;i>=0;i--) {
            dp1[i]=Math.max(nums[i]+dp1[i+2],dp1[i+1]);
        }
        for(int i=n-1;i>=1;i--) {
           dp2[i-1]=Math.max(nums[i]+dp2[i+1],dp2[i]);
        }
        return Math.max(dp1[0],dp2[0]);
    }
}